Skip to main content

Binary Tree Preorder Traversal

Problem Description​

Given the root of a binary tree, return the preorder traversal of its nodes' values.

Examples​

Example 1:


Input: root = [1,null,2,3]
Output: [1,2,3]

Example 2:

Input: root = []
Output: []

Example 3:

Input: root = [1]
Output: [1]

Constraints​

  • The number of nodes in the tree is in the range [0,100][0, 100].
  • βˆ’100<=Node.val<=100-100 <= Node.val <= 100

Code in Different Languages​

Written by @mahek0620
 # Definition for a binary tree node.
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right

class Solution:
def preorderTraversal(self, root):
if not root:
return []
result = []
stack = [root]
while stack:
node = stack.pop()
result.append(node.val)
if node.right:
stack.append(node.right)
if node.left:
stack.append(node.left)
return result

References​